:root,
:host {
  --van-radio-size: 20px;
  --van-radio-dot-size: 8px;
  --van-radio-border-color: var(--van-gray-5);
  --van-radio-duration: var(--van-duration-fast);
  --van-radio-label-margin: var(--van-padding-xs);
  --van-radio-label-color: var(--van-text-color);
  --van-radio-checked-icon-color: var(--van-primary-color);
  --van-radio-disabled-icon-color: var(--van-gray-5);
  --van-radio-disabled-label-color: var(--van-text-color-3);
  --van-radio-disabled-background: var(--van-border-color);
}

.van-radio {
  display: flex;
  align-items: center;
  overflow: hidden;
  cursor: pointer;
  user-select: none;

  &--disabled {
    cursor: not-allowed;
  }

  &--label-disabled {
    cursor: default;
  }

  &--horizontal {
    margin-right: var(--van-padding-sm);
  }

  &__icon {
    flex: none;
    height: 1em;
    font-size: var(--van-radio-size);
    line-height: 1em;
    cursor: pointer;

    .van-icon {
      display: block;
      box-sizing: border-box;
      width: 1.25em;
      height: 1.25em;
      color: transparent;
      font-size: 0.8em;
      line-height: 1.25;
      text-align: center;
      border: 1px solid var(--van-radio-border-color);
      transition-duration: var(--van-radio-duration);
      transition-property: color, border-color, background-color;
    }

    &--round {
      .van-icon {
        border-radius: 100%;
      }
    }

    &--dot {
      position: relative;
      border-radius: 100%;
      box-sizing: border-box;
      width: var(--van-radio-size);
      height: var(--van-radio-size);
      border: 1px solid var(--van-radio-border-color);
      transition-duration: var(--van-radio-duration);
      transition-property: border-color;

      &__icon {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        border-radius: 100%;
        height: calc(100% - var(--van-radio-dot-size));
        width: calc(100% - var(--van-radio-dot-size));
        transition-duration: var(--van-radio-duration);
        transition-property: background-color;
      }
    }

    &--checked {
      .van-icon {
        color: var(--van-white);
        background-color: var(--van-radio-checked-icon-color);
        border-color: var(--van-radio-checked-icon-color);
      }

      &.van-radio__icon--dot {
        border-color: var(--van-radio-checked-icon-color);
        .van-radio__icon--dot__icon {
          background: var(--van-radio-checked-icon-color);
        }
      }
    }

    &--disabled {
      cursor: not-allowed;

      .van-icon {
        background-color: var(--van-radio-disabled-background);
        border-color: var(--van-radio-disabled-icon-color);
      }
    }

    &--disabled&--checked {
      .van-icon {
        color: var(--van-radio-disabled-icon-color);
      }
    }
  }

  &__label {
    margin-left: var(--van-radio-label-margin);
    color: var(--van-radio-label-color);
    line-height: var(--van-radio-size);

    &--left {
      margin: 0 var(--van-radio-label-margin) 0 0;
    }

    &--disabled {
      color: var(--van-radio-disabled-label-color);
    }
  }
}
